// pages/login/login.js
/*登录说明
  1.收集表单项数据
  2.前端验证
    1）验证用户信息是否合法（账号密码的格式）
    2）前端验证不通过，就提示用户内容不合法，不需要发请求进行后端验证
    3）前端验证通过，发请求(账号，密码)进行后端验证
  3.后端验证
    1）验证当前用户是否存在
    2）如果该用户不存在，直接返回登录失败（该用户不存在）
    3）该用户存在，需要验证密码是否正确
    4)密码不正确，返回给前端，病提示密码不正确
    5）密码正确，返回登录成功数据
 */
import request from '../../utils/request'
Page({

  /**
   * 页面的初始数据
   */
  data: {
    phone: '',
    password: ''
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {

  },
  // 表单项事件回调
  handleInput(event){
    // console.log(event);
    let type = event.currentTarget.id
    this.setData({
      [type]: event.detail.value
    })
  },
  // 登录回调
  async login(){
    //收集表单数据
    let {phone,password} = this.data;
    // 前端验证
    /*
    手机号验证
      1.内容为空
      2，格式不正确
      3.手机号格式正确 验证通过
     */
     if(!phone){//内容为空
      //  提示用户
       wx.showToast({
         title:'手机号不能为空',
         icon:'error'
       })
       return 
     }
     //定义正则表达式
     let phoneReg = /^1(3|4|5|6|7|8|9)\d{9}$/;
     if(!phoneReg.test(phone)){
       //  提示用户
       wx.showToast({
        title:'手机号格式错误',
        icon:'error'
      })
      return
     }
    //  验证密码
    if(!password){
      wx.showToast({
        title:'密码不能为空',
        icon: 'error'
      })
      return
    }
    // 后端验证
    let result = await request('/login/cellphone',{phone,password,isLogin:true})
    if(result.code ===200){
      //登录成功
      wx.showToast({
        title: '登录成功'
      })
      // 将用户信息存入至本地
      wx.setStorageSync('userInfo',result.profile)
      // 跳转至个人中心
      wx.reLaunch({
        url: '/pages/personal/personal',
      })
    }else if(result.code ===400){
      wx.showToast({
        title: '手机号错误',
        icon: 'none'
      })
    }else if(result.code ===502){
      wx.showToast({
        title: '密码错误',
        icon: 'none'
      })
    }else{
      wx.showToast({
        title: '登录失败，请重新登录',
        icon:'none'
      })
    }
  },
  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady: function () {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow: function () {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide: function () {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload: function () {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh: function () {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage: function () {

  }
})